


<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>封装_简易axios-注册用户</title>
</head>
<body>
    <button class="reg-btn">注册用户</button>


    <script>


        function myAxios(config) {
            return  new Promise((resolve,reject)=>{
                const  xhr = new XMLHttpRequest()
                 // 1. 判断有params选项，携带查询参数
                if (config.params) {
                    const paramsObj = new URLSearchParams(config.params)
                    const queryString = paramsObj.toString()
                    config.url += `?${queryString}`
                }


                xhr.open(config.method || 'get',config.url)
        
                xhr.addEventListener("loadend",function () {
                    // xhr如何判断响应成功还是失败的？
                    // 2xx开头的都是成功响应状态码
                    if (xhr.status>=200 && xhr.status < 300) {
                        resolve(JSON.parse(xhr.response))
                    } else {
                        reject(new Error(xhr.response))
                    }           
                })

                if (config.data) {
                    const jsonStr = JSON.stringify(config.data)
                    // 设置请求头 内容类型
                    xhr.setRequestHeader('Content-Type', 'application/json');
                    xhr.send(jsonStr)
                } else {
                    xhr.send()
                    
                }


            })
        }
   
        // 通过 XHR 提交用户名和密码，完成注册功能
        document.querySelector(".reg-btn").addEventListener("click",function () {
            
            myAxios({
                url:"http://hmajax.itheima.net/api/register",
                method:"POST",
                data:{
                    username:"2409aaaa",
                    password:"111111"
                }
            }).then(res=>{
                console.log(res);           
                
            }).catch(err=>{
                // 详细打印
                console.dir(err)
              
            })
            
        })


    </script>
</body>
</html>